C#实现WinForm下DataGridView控件从剪切板中进行内容粘贴

您所在的位置:网站首页 winform gridview C#实现WinForm下DataGridView控件从剪切板中进行内容粘贴

C#实现WinForm下DataGridView控件从剪切板中进行内容粘贴

2023-08-17 20:28| 来源: 网络整理| 查看: 265

DataGridView是C#中在处理显示表格数据时常用的控件,但是在使用过程中,会发现复制DataGridView控件中的内容比较容易,而把剪切板中拷贝的内容黏贴到DataGridView控件中比较复杂,下面用一种简单的方式实现复制功能:

代码如下: DataGridView的KeyDown事件+黏贴数据方法

/// /// DataGridView的KeyDown事件 /// /// /// private void dgv_KeyDown(object sender, KeyEventArgs e) { //判断是否按下:Ctrl+V if (Control.ModifierKeys == Keys.Control && e.KeyCode == Keys.V) { //对象不为null,且对象为DataGridView类型 if (sender != null && sender.GetType() == typeof(DataGridView)) DataGirdViewCellPaste((DataGridView)sender);//调用黏贴方法 } } /// /// 向DataGridView控件粘贴数据 /// public void DataGirdViewCellPaste(DataGridView dgv) { if (dgv.CurrentCell == null)//判断当前单元格已选中,复制黏贴单元格初始位置 return; int insertRowIndex = dgv.CurrentCell.RowIndex;//获取当前单元格行索引,打印单元格内容调用 int insertColIndex = dgv.CurrentCell.ColumnIndex;//获取当前单元格列索引,打印单元格内容调用 string pasteText = Clipboard.GetText();//获取当前剪切板的内容(黏贴内容必须是表格形式) if (string.IsNullOrEmpty(pasteText))//剪贴板内容不为空 return; #region 获取剪贴板内容的行、列数 //剪切板内容:21\t\t\r\n11\t12\r\n(\t:表示空格;\r\n:表示换行) #region 获取行数 char[] c = pasteText.ToCharArray();//化整为零,将字符串转化成字符数组,逐个遍历 int RowCount = 0;//行数初始为零 for (int i = 0; i RowCount++; } } //判断复制范围是否在最大行范围内:(黏贴内容行数-1)+(当前单元格行索引值+1) > 表格总行数 //(黏贴内容行数 -1):因为有一行刚好黏贴在当前行 if (RowCount + insertRowIndex > dgv.RowCount) { MessageBox.Show("粘贴的行数不正确"); return; } #endregion #region 获取列数 string[] s = pasteText.Split(new char[] { '\r', '\n' });//根据'/r'、'/n',把数据分为行单位内容 string[] Col = s[0].Split('\t');//根据'\t',获取每行单元格数,也就是列数 int ColCount = Col.Length;//列数 //判断复制范围是否在最列行范围内:(黏贴内容列数-1)+(当前单元格列索引值+1) > 表格总列数 if (ColCount + insertColIndex > dgv.ColumnCount) { MessageBox.Show("粘贴的列数不正确"); return; } #endregion #endregion #region 黏贴单元格内容 List listRow = new List();//声明集合,存储行单位内容 for (int i = 0; i listRow.Add(s[i]); } } //黏贴单元格内容到表格上 for (int iR = 0; iR //注意黏贴单元格索引位置:在当前单元格的初始索引上叠加 dgv[iC + insertColIndex, iR + insertRowIndex].Value = listRow[iR].Split('\t')[iC]; // listRow[iR]:第[iR+1]行单元格内容 // listRow[iR].Split('\t'):把第[iR+1]行单元格内容划分 // listRow[iR].Split('\t')[iC]:提取第[iR+1]行的第[iC+1]个单元格内容 } } #endregion } *注意:此方法目前只测试了,从Excel或是Word的表格向DataGridView控件粘贴内容


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3